<?php
/**
 * @title 888. 公平的糖果棒交换 - 哈希
 * @author start2004
 */

// ini_set("memory_limit", "128M");

// class Solution {
//
//     function find() {
//
//     }
// }

class Solution {

    /**
     * @param Integer[] $A
     * @param Integer[] $B
     * @return Integer[]
     */
    function fairCandySwap($A, $B) {
        /**
         * @since 2021-02-07 总和, 哈希
         */
        $sumB = 0;
        $hashB = [];
        for ($i=0, $lenB=count($B); $i<$lenB; $i++){
            $sumB += $B[$i];
            $hashB[$B[$i]] = 1;
        }

        /**
         * @since 2021-02-07 差值
         */
        $sumA = array_sum($A);
        $diff = ($sumB-$sumA)>>1;

        /**
         * @since 2021-02-07 查找可能性
         */
        for ($i=0, $lenA=count($A); $i<$lenA; $i++){
            $k = $A[$i]+$diff;
            if(isset($hashB[$k])){
                /**
                 * @return
                 */
                return [$A[$i], $k];
            } else {}
        }

        /**
         * @return
         */
        return false;
    }
}


/**
 * @url http://127.0.0.1/leetcode/202102/2021.02.01.php
 */
$datas = [
    [[1,1],[2,2]], // [1,2]
    [[1,2],[2,3]], // [2,3]
    [[2], [1,3]], // [2,3]
    [[1,2,5], [2,4]], // [5,4]
];

include_once dirname(__DIR__) . DIRECTORY_SEPARATOR ."xhprof.php";
$xhprof = new Xhprof();
foreach ($datas as $data){
    var_dump($data);

    $obj = new Solution();
    $result = $obj->fairCandySwap(...$data);
    // $result = $obj->($xhprof->tree($data));
    // $result = $obj->($xhprof->listNode($data));
    // $result = $obj->find(...$data);
    var_dump($result);
    // if(count($result)<=20){
    //     var_dump($result);
    // } else {
    //     var_dump(count($result));
    // }
    echo str_repeat(PHP_EOL, 3);
    echo str_repeat("<br>", 3);
}

// foreach ($datas as $data){
//     $obj = new $data[0][0](...$data[1][0]);
//
//     for ($i=1; $i<count($data[0]); $i++){
//         $result = $obj->$data[0][$i](...$data[1][$i]);
//
//         echo $data[0][$i] ."(\"". implode(",", $data[1][$i]) ."\") ";
//             if($result === true){
//                 echo "True";
//             } elseif($result === false) {
//                 echo "False";
//             } elseif($result === null) {
//                 echo "Null";
//             } elseif(is_array($result)) {
//                 var_dump($result);
//             } else {
//                 echo $result;
//             }
//         echo PHP_EOL;
//     }
//
//     echo str_repeat(PHP_EOL, 3);
// }
$xhprof->end();
